草庐IT

tcp 序列号

全部标签

node.js - 如果 TCP 服务器(nodejs)发送没有分隔符的数据,TCP 客户端(golang)如何知道数据何时结束 "\n"

我的问题:我正在尝试读取TCP服务器(nodejs)发送的数据但我不能,服务器发送数据时没有分隔线“\r\n”或“\n”我是Golang的新手,但我一直在尝试很多方法来获取服务器发送的所有数据。来自Server.js的代码,这是一个简单的示例varnet=require('net');varserver=net.createServer(function(socket){console.log("NewClient")socket.on('data',function(data){console.log("data",data,data.toString())socket.write(

regex - Golang 正则表达式匹配字符串直到给定的字符序列

我有一个字符串,可以有一个-name后跟值(可以有空格),也可以有-descr后跟一个值(-descr后跟值可能不存在):示例字符串:runcmd-nameabcdxyz-descrabcdef或runcmd-nameabcdxyz使用Go语言,我该如何编写正则表达式,它会返回-descr之前的字符串(如果它存在)。所以,对于上面的两个例子,结果应该是:runcmd-nameabcdxyz我在尝试:regexp.MustCompile(`(-name).+?=-descr`)但是,那没有返回任何匹配项。我想知道正确的正则表达式来获取字符串直到-descr如果它存在

go - TCP 连接似乎一次读取了太多字节

我正在用Go编写一个FTP服务器,但在列出文件/目录时遇到了问题。似乎正在发生的事情是服务器正在分别且正确地发送文件,但是当从连接中读取它们时,它们一次被读取多个。我已经尝试更改缓冲区大小以及在发送每个文件名之前发送确认,但是当从连接读取时它最终读取的字节数比预期的多。这是来自服务器的相关部分:for_,fn:=rangefiles{conn.Write([]byte(fn.Name()))}上面代码中,files是[]os.FileInfo从ioutil.ReadDir("./")获取文件在当前目录中。测试时,它会发送正确的文件名以及每个名称的正确字节。在客户端我有这个:varbuf

linux - http: 接受错误:接受 tcp [::]:8080: accept4: 打开的文件太多;

我已经用Golang编写了RESTAPI,并且正在使用Jmeter对我的API进行性能测试。当我对300个或更多用户运行测试时,每个用户发送20个请求,每个请求之间的间隔为500毫秒,我收到以下错误:http:Accepterror:accepttcp[::]:8080:accept4:toomanyopenfiles;我在AWSEC2服务器上运行这个Go应用程序。我在8GBRAM机器上运行这个应用程序。以下是我已经尝试过的:我已将ulimit增加到一个足够好的数字。当我运行ulimit-n命令时,输出为:1048576在我的代码中,我确保响应主体已关闭。但是,这些都没有解决问题。任何

linux - 从 TCP 连接获取 HTTP header

我正在用golang为Linux编写类似应用程序的代理程序。该应用程序在执行时将监听所有TCP连接并将它们重定向到代理服务器地址。在应用程序之间还向HTTPheader添加了“Proxy-Authorisation:Basic...”header。当我看到TCPheader时,我无法获得HTTPheader。我哪里出错了或如何提取HTTP数据?还有其他方法可以实现吗? 最佳答案 我也是golang的新手,但就从tcp套接字获取HTTP数据而言,下面的代码对我有用。packagemainimport"net"import"fmt"im

http - TCP 是同一主机中 Go 程序之间通信的最佳方法吗?

假设我有两个独立的Go程序在我的本地主机上运行,​​就性能而言,TCP是否是在两个程序之间传输数据的最佳方法? 最佳答案 简短的回答是否定的。TCP/IP堆栈很慢,尤其是TCP部分。因此,就性能而言,您最好使用本地进程间通信方法,例如应用程序或Unix套接字之间的共享内存。如果您必须使用网络堆栈进行通信(例如,您计划在主机之间移动应用程序),那么UDP或原始套接字是性能方面的最佳选择。只有当你:必须使用网络并且您需要一个可靠的通信channel,那么TCP是一个不错的选择。因此,只需浏览您的要求并确定它是否是最适合您的方法。

go - 序列化为JSON动态结构

所有使用JSON的示例都描述了如何序列化为JSON简单类型或用户类型(如结构)。但我有不同的情况:a)我不知道我的类型/对象的字段b)每个对象都有不同的类型。这是我的案例的伪代码:while`select*fromitem`dowhile`selectfieldname,fieldvaluefromfieldswherefields.itemid=item.id`do...对于我数据库中的每个实体,我都获得了字段名称和字段值。结果我需要得到这样的东西:{"item.field1":value,..."item.fieldN":value,"custom_fields":{"fields

go - 在 TCP 连接的端口上发送 UDP 数据包

关闭。这个问题需要detailsorclarity.它目前不接受答案。想改善这个问题吗?通过editingthispost添加详细信息并澄清问题.3年前关闭。Improvethisquestion我有一个GolangTCP服务器,即net.TCPConn,连接在一个端口上,除了TCP流之外,它还必须接收UDP数据包并以UDP数据包进行响应。传入的UDP数据包在服务器上弹出(来自net.TCPConn.Read()),但我不知道如何再次发回UDP数据包。所有UDP写入方法仅适用于net.UDPConn.net.UDPConn.WriteMsgUDP()诱人地谈论它是应用于连接的还是非连接

for-loop - 从 go 中的 tcp 连接读取数据是否需要 for 循环?

有一个func来处理tcp连接:for{select{caseconn:=我的问题是,如果你使用for循环,你必须写return否则它会是一个死循环。如果它返回,这个handleClient函数将只执行一次。所以这里不需要for,对吧?我们仍然可以在没有for的情况下读取所有数据,这是正确的思考方式吗? 最佳答案 服务器处理连接的常见模式可能是funchandleClient(connnet.Conn){r:=bufio.NewReader(conn)for{line,err:=r.ReadBytes(byte('\n'))swit

go - 按 createdDate golang 排序列表

我有一个返回Inspections的模型实例的函数,我想按CreatedDate对它进行排序,但是在我编译之后我得到了cannotuseinspections[i].CreatedDate(typestring)astypeboolinreturnargumentinspection.go是typeInspectionstruct{Idint64`db:"id,omitempty"json:"id,omitempty"`CreatedDatestring`db:"created,omitempty"json:"created_date,omitempty"`Records[]*Insp